Vue change image on hover:To change an image on hover in Vue, you can use the v-bind directive to bind the image source to a data property, and the v-on directive to listen for the “mouseover” and “mouseout” events to change the source of the image.
First, create a data property to store the source of the image. Then, use v-bind to bind the “src” attribute of the image tag to the data property.
Next, use v-on to listen for the “mouseover” event on the image tag. When the event is triggered, update the data property with the new source of the image. Similarly, listen for the “mouseout” event to change the image source back to the original source.
Finally, add some CSS styles to the image tag to adjust its size and position on hover.
How can I use Vue to change an image when hovering over it?
This code creates a Vue app that binds an image source to the “imageSrc” data property. The “changeImage” method is triggered when hovering over the image, and it updates the “imageSrc” property with a new image source. Similarly, the “resetImage” method is triggered when the mouse leaves the image, and it resets the “imageSrc” property to its original value. By using Vue’s data-binding and event-handling features, we can dynamically change the image displayed on hover, without needing to manually manipulate the DOM.
Vue change image on hover Example
<div id="app">
<img v-bind:src="imageSrc" v-on:mouseover="changeImage" v-on:mouseout="resetImage">
</div>
<script type="module">
const app = new Vue({
el: "#app",
data() {
return {
imageSrc: 'https://www.sarkarinaukriexams.com/images/editor/1691754318flower-gf39467e8f_640.jpg'
}
},
methods: {
changeImage() {
this.imageSrc = 'https://pixabay.com/get/g3effffe9c284b24a25793486c24e489913eb1c13416a5c42fd128ad5c13ec5136547255509360d5e5d3158f6a71c6093fc89ff7175f85725ca2b7883df0e413c_640.jpg'
},
resetImage() {
this.imageSrc = 'https://pixabay.com/get/g88ef216637000d58acf8b5b22f060cbab194a5d4395d681b7fbdb2a59bdbb806a7614f0b28fbc72e78f540588b530e0b893ee974dc4a8848e2fb4a981a9f55d6_640.jpg'
}
}
});
</script>